<template>
  <div class="like-page">
    <van-nav-bar fixed title="我的点赞" />
    <van-list
      v-model="loading"
      :finished="finished"
      finished-text="没有更多了"
      @load="onLoad"
    >
    <article-item :article="item" v-for="item in rows" :key="item.id" />
    </van-list>
  </div>
</template>

<script>
import { getArticlesCollect } from '@/api/article'
export default {
  name: 'like-page',
  data () {
    return {
      loading: false,
      // 是否全部加载完毕, 默认为 false 只要改为 true 就永远不会再触发加载更多了
      // 设置 finished 为 true 后底部文本会自动改为没有更多了!
      finished: false,
      current: 1,
      // 推荐是 weight_desc
      // 最新可以不传: ''
      sorter: 'weight_desc',
      rows: []
    }
  },
  methods: {
    async onLoad () {
      const res = await getArticlesCollect({
        optType: 1,
        page: this.current,
        pageSize: 10
      })

      // console.log(res)
      // this.rows = res.data.data.rows
      this.rows.push(...res.data.data.rows)
      // this.rows = this.rows.concat(res.data.data.rows)
      // this.rows = [...this.rows, ...res.data.data.rows]

      // 将 loading 设置为 false
      this.loading = false

      // 防止过度操作导致的其他 Bug
      // 写代码时要考虑到代码的健壮性
      if (this.current >= res.data.data.pageTotal) {
        // 加载完毕了
        this.finished = true
      }

      // 加载完毕后让 current 自增
      this.current++
    }
  }
}
</script>

<style lang="less" scoped>
.like-page {
  margin-bottom: 50px;
  margin-top: 44px;
}
</style>
